

## **EXPERIMENT 5**

# Use of XOR/XNOR Gates to Generate & Check Parity

Department of Electrical & Computer Engineering

#### I. OBJECTIVES:

• Demonstrate the use of XOR and XNOR gates to generate and check parity.

### **II. MATERIALS:**

- Xilinx Vivado software, student or professional edition V2018.2 or higher.
- IBM or compatible computer with Pentium III or higher, 128 M-byte RAM or more, and 8 G-byte Or larger hard drive.
- BASYS 3 Board.

## **III. DISCUSSION:**

A parity checker circuit is used to detect a 1-bit error, as could occur in data transmission. Such an error can be caused by an electrical noise "hit", or by a hardware failure such as a bit "stuck at 0" or "stuck at 1". Parity can be even or odd and requires that an extra bit (the parity bit) be generated and "tacked onto" the data. The value of the parity bit is derived from the data. The following examples illustrate even and odd parity.

#### 1) Even parity

Determine the parity bit for the 4 bit data 1001 using even parity.

The number of 1 bit in 1001 is 2, an even number. To have even parity for this data, we must keep the total number of 1s, including the parity bit, even. Hence, the parity bit should be a 0. Note that, as a binary number, 1001 is odd (value is 9). But whether the value of 1001 is odd or even is not important. Only the number of 1s is important.

Data: 1001 Parity bit: 0 Data with parity: 10010

#### 2) Odd Parity

Determine the parity bit for the 8 bit data 10110111.

The number of 1 bit in 10110111 is 6, an even number. To have even parity for this data, we must make sure the total number of 1s, including the parity bit, is an odd number. Therefore, the parity bit must be 1. Again, the numerical value of the data is not important, all that counts is the number of 1s in the data.

Data: 10110111 Parity bit: 1 Data with parity: 101101111

#### **IV. PROCEDURE:**

- 1. Open Xilinix Vivado and in the Xilinx-Project Navigator window, Quick start, New Project.
- 2. Choose "RTL Project" and check the "Do not specify sources at this time" as we will configure all the settings manually through the navigator from inside the project.

| ojec    | ject Type                                                                                                                                                                        |          |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| ecify   | ify the type of project to create.                                                                                                                                               |          |
| ۲       | BTL Project<br>You will be able to add sources, create block designs in IP Integrator, generate IP, run RTL analysis, synthesis<br>implementation, design planning and analysis. |          |
|         | Do not specify sources at this time                                                                                                                                              |          |
| 0       | Post-synthesis Project: You will be able to add sources, view device resources, run design analysis, planning implementation.                                                    | and      |
|         | Do not specify sources at this time                                                                                                                                              |          |
| $\circ$ | J/O Planning Project<br>Do not specify design sources. You will be able to view part/package resources.                                                                          |          |
| 0       | Imported Project<br>Create a Vivado project from a Synplify, XST or ISE Project File.                                                                                            |          |
| 0       | Example Project<br>Create a new Vivado project from a predefined template.                                                                                                       |          |
|         |                                                                                                                                                                                  |          |
|         |                                                                                                                                                                                  |          |
|         |                                                                                                                                                                                  |          |
|         |                                                                                                                                                                                  |          |
| 2       | < <u>B</u> ack <u>N</u> ext > <u>F</u> inish                                                                                                                                     | Cancel   |
|         |                                                                                                                                                                                  |          |
|         |                                                                                                                                                                                  |          |
|         |                                                                                                                                                                                  |          |
|         |                                                                                                                                                                                  | - 2   12 |
|         | P a g                                                                                                                                                                            | ezitz    |

3. Select New Source... and the New window appears. In the New window, choose Schematic, type your file name (such as *eparity*) in the File Name editor box, click on OK, and then click on the Next button.

| 🍌 Create Source File       |                                    |           |  |  |  |  |  |
|----------------------------|------------------------------------|-----------|--|--|--|--|--|
| Create a new s<br>project. | 4                                  |           |  |  |  |  |  |
| <u>F</u> ile type:         | File type: • VHDL                  |           |  |  |  |  |  |
| F <u>i</u> le name:        | eparity                            | $\otimes$ |  |  |  |  |  |
| Fil <u>e</u> location:     | 🖬 <local project="" to=""></local> | ~         |  |  |  |  |  |
| ?                          | ОК                                 | Cancel    |  |  |  |  |  |

4. In the Xilinx - Project Navigator window, select the following

- Category: "General Purpose"
- Family: "Artix-7"
- Package: "cpg236"
- Speed: "-1"
- Choose "xc7a35tcpg236-1" that corresponds to the board we are using.
- Then Choose Finish.

| Parts     | Filtoro    |               |                |             |             |            |           |         |       |
|-----------|------------|---------------|----------------|-------------|-------------|------------|-----------|---------|-------|
| Category: | General Pu | Irpose        | ~              | Package:    | cpg236      | ~ Tempe    | rature: I |         | ~     |
| Family:   | Artix-7    |               | ~              | Speed:      | -1L         | ~          |           |         |       |
|           |            |               |                |             |             |            |           |         |       |
| Search:   | Q- xc7a35  | ticpg         | S ~            | (1 match)   |             |            |           |         |       |
| Part      |            | I/O Pin Count | Available IOBs | LUT Element | s FlipFlops | Block RAMs | Ultra R   | AMs DSF | Ps Gt |
| xc7a35ti  | cpg236-1L  | 236           | 106            | 20800       | 41600       | 50         | 0         | 90      | 2     |
|           |            |               |                |             |             |            |           |         |       |
|           |            |               |                |             |             |            |           |         |       |
| <         |            | _             |                |             |             |            |           |         | >     |

5. The Define Module Window that will appear, we will choose the input and output labels for the gates under investigation in this experiment. In this experiment, we have a bit victor as an input data. Then Under "Port Name", add "clk" as input and then add "Data\_Tx" and "Data\_Rx" then check the "Bus" and make the "MSB" equal to 7 as we are designing an 8-bit parity check. Then, add "Parity", as in/output as it will be output from the transmitter stage then input to the Rx stage. Alsi, add "Error" as output and select OK.

| r each port specified:<br>MSB and LSB values will be ignored unless its Bus column is checked. |                                            |       |              |     |     |  |   |  |  |
|------------------------------------------------------------------------------------------------|--------------------------------------------|-------|--------------|-----|-----|--|---|--|--|
| Ports with blank                                                                               | orts with blank names will not be written. |       |              |     |     |  |   |  |  |
|                                                                                                |                                            |       |              |     |     |  |   |  |  |
| lodule Definitio                                                                               | 1                                          |       |              |     |     |  |   |  |  |
| Entity name:                                                                                   | e                                          | epari | y            |     |     |  | 8 |  |  |
| Architecture n                                                                                 | ame: F                                     | Beha  | vioral       |     |     |  | 8 |  |  |
| -                                                                                              |                                            |       |              |     |     |  |   |  |  |
| I/O Port Defin                                                                                 | itions                                     |       |              |     |     |  |   |  |  |
| +  -                                                                                           | 1                                          | Į.    |              |     |     |  |   |  |  |
| Port Name                                                                                      | Direct                                     | ion   | Bus          | MSB | LSB |  |   |  |  |
| clk                                                                                            | in                                         | ~     |              | 0   | 0   |  |   |  |  |
|                                                                                                | in                                         | ~     | $\checkmark$ | 7   | 0   |  |   |  |  |
| Data_Tx                                                                                        | in                                         | ~     | $\checkmark$ | 7   | 0   |  |   |  |  |
| Data_Tx<br>Data_Rx                                                                             |                                            |       |              | 0   | 0   |  |   |  |  |
| Data_Tx<br>Data_Rx<br>Parity                                                                   | inout                                      | ~     |              |     | 0   |  |   |  |  |
| Data_Tx<br>Data_Rx<br>Parity<br>Error                                                          | inout<br>out                               | ~     |              | 0   | 0   |  |   |  |  |

6. In the "eparity.vhd" created file, type the gates equivalent VHDL code for the 8-bit even parity transmitter/ receiver between the "begin" and "end Behavioral" as follows and then save the file.

```
46
     --end loop l parity ;
47
       --Parity <= temp ;
49 | use IEEE.numeric std.all;
50 🖯 entity eparity is
51 | port(
                   : in std logic;
52
    clk
53 i
    Data Tx
                   : in std logic vector(7 downto 0);
                   : in std logic_vector(7 downto 0);
    Data Rx
54
55
                   : inout std logic;
    Parity
56 ;
    Error
                  : out std logic);
57 🔶 end eparity;
58 🖯 architecture rtl of eparity is
59 🕴 signal temp data
                           : std logic vector(7 downto 0);
60 signal temp rx
                        : std logic vector(8 downto 0);
61 ¦ begin
62 
p parity check : process (clk)
63 variable vparity : std logic;
64 variable rxparity
                          : std logic;
65 begin
66 🖯
      if rising edge(clk) then
67
       -- Tx
68
      temp_data <= Data_Tx;</pre>
69
      vparity := '0';
70 !
      rxparity := '0';
71 🖯
       l_parity : for k in 0 to 7 loop
    vparity := vparity xor temp_data(k);
72 :
73 🗀
      end loop l_parity;
74 : ----- Rx
    parity <= vparity;</pre>
75 ¦
76
       temp rx <= Data Rx & Parity;
77 🗔
      Rx_parity : for k in 0 to 8 loop
78
            rxparity := rxparity xor temp rx(k);
79 🖂
          end loop Rx_parity;
80 🛆
       end if;
81 :
       Error <= rxparity;
83 🔶 end rtl;
```

Page 5 | 12

7. Next, we need to add To add a constraint file with the".xdc" extension, as following: Go to "Flow Navigator" and from "Project Manager" select "Add Sources" then "Add or create constraints". Next, choose "Create File" and enter the file name "lab\_2" then "OK" followed by "Finish".

| À Add Sources    |                                                                                                                                                                                         | $\times$ |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| HLx Editions     | Add Sources This guides you through the process of adding and creating sources for your project Add or greate constraints Add or create design sources Add or create simulation sources |          |
| <b>£</b> XILINX. |                                                                                                                                                                                         |          |
| ?                | < <u>B</u> ack <u>N</u> ext > <u>F</u> inish                                                                                                                                            | Cancel   |

8. Then, we need to get a template xdc file that is going to be edited according to the different experiments. Google "basys 3 xdc file" and choose the "xilinix" link that appears (<u>https://www.xilinx.com/support/documentation/university/Vivado-Teaching/HDL-Design/2015x/Basys3/Supporting%20Material/Basys3\_Master.xdc</u>). Copy the whole file and paste it into the "port\_assign.xdc" that you have just created in the last step. Then uncomment and edit the input Switches and the output LEDs as in the next step.

```
4 ## - rename the used ports (in each line, after get ports) according to the top level signal names in the project
 5
 6 ## Clock signal
 7
    set_property PACKAGE_PIN W5 [get_ports clk]
 8
        set property IOSTANDARD LVCMOS33 [get ports clk]
 9
        create clock -add -name sys_clk_pin -period 10.00 -waveform {0 5} [get ports clk]
10
11 ## Switches
12 | set property PACKAGE_PIN V17 [get ports {Data_Tx[0]}]
13
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Tx[0]}]
14
    set property PACKAGE PIN V16 [get ports {Data Tx[1]}]
15
        set property IOSTANDARD LVCMOS33 [get ports {Data_Tx[1]}]
16
    set property PACKAGE_PIN W16 [get ports {Data_Tx[2]}]
17
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Tx[2]}]
18
    set property PACKAGE PIN W17 [get ports {Data Tx[3]}]
19
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Tx[3]}]
20
    set property PACKAGE_PIN W15 [get_ports {Data_Tx[4]}]
21
        set property IOSTANDARD LVCMOS33 [get ports {Data_Tx[4]}]
22
    set property PACKAGE_PIN V15 [get ports {Data_Tx[5]}]
23
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Tx[5]}]
24
    set property PACKAGE PIN W14 [get ports {Data Tx[6]}]
25
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Tx[6]}]
26 | set property PACKAGE PIN W13 [get ports {Data Tx[7]}]
27
        set property IOSTANDARD LVCMOS33 [get ports {Data_Tx[7]}]
    set_property PACKAGE_PIN V2 [get_ports {Data_Rx[0]}]
28
29
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Rx[0]}]
    set property PACKAGE_PIN T3 [get_ports {Data_Rx[1]}]
30
31
        set property IOSTANDARD LVCMOS33 [get ports {Data_Rx[1]}]
32 set_property PACKAGE_PIN T2 [get_ports {Data_Rx[2]}]
       set_property_IOSTANDARD_LVCMOS33 [get_ports {Data_Rx[2]}]
33
34 | set_property PACKAGE_PIN R3 [get_ports {Data_Rx[3]}]
35
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Rx[3]}]
36 | set_property PACKAGE_PIN W2 [get_ports {Data_Rx[4]}]
37
        set_property IOSTANDARD LVCMOS33 [get_ports {Data_Rx[4]}]
38
   set property PACKAGE_PIN U1 [get ports {Data_Rx[5]}]
       set_property IOSTANDARD LVCMOS33 [get_ports {Data_Rx[5]}]
39
40 set property PACKAGE_PIN T1 [get ports {Data_Rx[6]}]
       set_property IOSTANDARD LVCMOS33 [get_ports {Data_Rx[6]}]
41
  set property PACKAGE_PIN R2 [get ports {Data_Rx[7]}]
42
      set property IOSTANDARD LVCMOS33 [get_ports {Data_Rx[7]}]
43
44
45
46 ## LEDs
47 set_property PACKAGE_PIN U16 [get_ports {Parity}]
       set property IOSTANDARD LVCMOS33 [get ports {Parity}]
48
49 set_property PACKAGE_PIN E19 [get_ports {Error}]
50
       set property IOSTANDARD LVCMOS33 [get ports {Error}]
51 #set_property PACKAGE_PIN U19 [get_ports {led[2]}]
52
        #set_property IOSTANDARD LVCMOS33 [get_ports {led[2]}]
53 #set property PACKAGE PIN V19 [get ports {led[3]}]
        #set_property IOSTANDARD LVCMOS33 [get_ports {led[3]}]
54
55 #set property PACKAGE PIN W18 [get ports {led[4]}]
```

Page 7 | 12

9. From the tool tab choose the play button and then "Run Implementation". Select "Number of jobs" =1 and then press OK.

| × |
|---|
|   |
|   |
|   |
|   |
|   |
|   |
|   |
|   |

10. The implementation errors window will appear if any or the successfully completed window. From this window select "Generate Bitstream" and then OK. This will make the software generate ".bin" file to be used in programing the hardware BAYAS 3.

| mplementation Completed                | × |
|----------------------------------------|---|
| Implementation successfully completed. |   |
| O Open Implemented Design              |   |
| Generate Bitstream                     |   |
| ◯ <u>V</u> iew Reports                 |   |
| Don't show this dialog again           |   |
| OK Cancel                              | ] |

11. The next window will appear in which choose "Open Hardware Manger", connect the Hardware Kit to the USB port and then press OK.

| Bitstream Generation Completed               | × |
|----------------------------------------------|---|
| Bitstream Generation successfully completed. |   |
| Open Implemented Design                      |   |
| ◯ <u>V</u> iew Reports                       |   |
| • Open <u>H</u> ardware Manager              |   |
| O Generate Memory Configuration File         |   |
| Don't show this dialog again                 |   |
| OK Cancel                                    |   |
| AP=1 +                                       |   |

12. From the window appears, select the ".bin" file from the Project you create by browsing for the generated ".bit file" under the ".runs" folder and program the board then press OK.

| 🖕 Specify Bitstream File |
|--------------------------|
| Look jn: impl_1          |
| liX 📹                    |
| Separity.bit             |
|                          |
|                          |

13. Check the Parity and the Error pattern on your board in the following cases,

| Data_Tx            | Parity | Data        | _Rx          | Error | Comments |
|--------------------|--------|-------------|--------------|-------|----------|
| <b>"0001 0101"</b> |        | "0001 0101" | No change    |       |          |
| <b>"0001 0101"</b> |        | "0001 0100" | 1-bit change |       |          |
| "0001 0101"        |        | "0001 0110" | 2-bit change |       |          |
| <b>"0001 0101"</b> |        | "1101 0100" | 3-bit change |       |          |
| <b>"0001 0101"</b> |        | "1110 0100" | 4-bit change |       |          |

14. List your comments from last step

Checked by\_\_\_\_\_ Date \_\_\_\_\_

#### V. Questions:

1. Draw the logic circuit for each of the following. For each gate, determine if it generates either EVEN or ODD parity bit and finds the output for the given input data:

(Remember: A XOR generates EVEN parity bit. A XNOR generates Odd Parity bit, whatever how many inputs they have.)

| Data Inputs                        | Which kind parity      | bit can it generate? |
|------------------------------------|------------------------|----------------------|
|                                    | <b>EVEN</b> Parity Bit | ODD Parity Bit       |
| 4-input XOR, input data=1001       |                        |                      |
| 5-input XOR, input data=1001 0     |                        |                      |
| 6-input XOR, input data=101001     |                        |                      |
| 7-input XNOR, input data = 1011011 |                        |                      |

2. We discussed how to construct an 8-bit even parity generator/checker using XOR gates, can you use XNOR gates to perform the same function? Draw the schematic diagram.

3. If you are asked to build an 8 bit odd parity generator/ checker with the output ERROR=1 when there is a 1 bit error, which type of gates, XOR or XNOR is simpler to use? Explain.

4. Why can't a parity generator/checker detect even-bit errors? Given an example in your explanation.

Page 12 | 12